fst2(0, Z) -> nil
fst2(s1(X), cons2(Y, Z)) -> cons2(Y, fst2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
len1(nil) -> 0
len1(cons2(X, Z)) -> s1(len1(Z))
↳ QTRS
↳ Non-Overlap Check
fst2(0, Z) -> nil
fst2(s1(X), cons2(Y, Z)) -> cons2(Y, fst2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
len1(nil) -> 0
len1(cons2(X, Z)) -> s1(len1(Z))
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
fst2(0, Z) -> nil
fst2(s1(X), cons2(Y, Z)) -> cons2(Y, fst2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
len1(nil) -> 0
len1(cons2(X, Z)) -> s1(len1(Z))
fst2(0, x0)
fst2(s1(x0), cons2(x1, x2))
from1(x0)
add2(0, x0)
add2(s1(x0), x1)
len1(nil)
len1(cons2(x0, x1))
ADD2(s1(X), Y) -> ADD2(X, Y)
LEN1(cons2(X, Z)) -> LEN1(Z)
FROM1(X) -> FROM1(s1(X))
FST2(s1(X), cons2(Y, Z)) -> FST2(X, Z)
fst2(0, Z) -> nil
fst2(s1(X), cons2(Y, Z)) -> cons2(Y, fst2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
len1(nil) -> 0
len1(cons2(X, Z)) -> s1(len1(Z))
fst2(0, x0)
fst2(s1(x0), cons2(x1, x2))
from1(x0)
add2(0, x0)
add2(s1(x0), x1)
len1(nil)
len1(cons2(x0, x1))
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
ADD2(s1(X), Y) -> ADD2(X, Y)
LEN1(cons2(X, Z)) -> LEN1(Z)
FROM1(X) -> FROM1(s1(X))
FST2(s1(X), cons2(Y, Z)) -> FST2(X, Z)
fst2(0, Z) -> nil
fst2(s1(X), cons2(Y, Z)) -> cons2(Y, fst2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
len1(nil) -> 0
len1(cons2(X, Z)) -> s1(len1(Z))
fst2(0, x0)
fst2(s1(x0), cons2(x1, x2))
from1(x0)
add2(0, x0)
add2(s1(x0), x1)
len1(nil)
len1(cons2(x0, x1))
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDP
↳ QDP
LEN1(cons2(X, Z)) -> LEN1(Z)
fst2(0, Z) -> nil
fst2(s1(X), cons2(Y, Z)) -> cons2(Y, fst2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
len1(nil) -> 0
len1(cons2(X, Z)) -> s1(len1(Z))
fst2(0, x0)
fst2(s1(x0), cons2(x1, x2))
from1(x0)
add2(0, x0)
add2(s1(x0), x1)
len1(nil)
len1(cons2(x0, x1))
The following pairs can be strictly oriented and are deleted.
The remaining pairs can at least by weakly be oriented.
LEN1(cons2(X, Z)) -> LEN1(Z)
cons2 > LEN1
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
↳ QDP
↳ QDP
fst2(0, Z) -> nil
fst2(s1(X), cons2(Y, Z)) -> cons2(Y, fst2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
len1(nil) -> 0
len1(cons2(X, Z)) -> s1(len1(Z))
fst2(0, x0)
fst2(s1(x0), cons2(x1, x2))
from1(x0)
add2(0, x0)
add2(s1(x0), x1)
len1(nil)
len1(cons2(x0, x1))
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDP
ADD2(s1(X), Y) -> ADD2(X, Y)
fst2(0, Z) -> nil
fst2(s1(X), cons2(Y, Z)) -> cons2(Y, fst2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
len1(nil) -> 0
len1(cons2(X, Z)) -> s1(len1(Z))
fst2(0, x0)
fst2(s1(x0), cons2(x1, x2))
from1(x0)
add2(0, x0)
add2(s1(x0), x1)
len1(nil)
len1(cons2(x0, x1))
The following pairs can be strictly oriented and are deleted.
The remaining pairs can at least by weakly be oriented.
ADD2(s1(X), Y) -> ADD2(X, Y)
[ADD1, s1]
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
↳ QDP
fst2(0, Z) -> nil
fst2(s1(X), cons2(Y, Z)) -> cons2(Y, fst2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
len1(nil) -> 0
len1(cons2(X, Z)) -> s1(len1(Z))
fst2(0, x0)
fst2(s1(x0), cons2(x1, x2))
from1(x0)
add2(0, x0)
add2(s1(x0), x1)
len1(nil)
len1(cons2(x0, x1))
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
FROM1(X) -> FROM1(s1(X))
fst2(0, Z) -> nil
fst2(s1(X), cons2(Y, Z)) -> cons2(Y, fst2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
len1(nil) -> 0
len1(cons2(X, Z)) -> s1(len1(Z))
fst2(0, x0)
fst2(s1(x0), cons2(x1, x2))
from1(x0)
add2(0, x0)
add2(s1(x0), x1)
len1(nil)
len1(cons2(x0, x1))
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
FST2(s1(X), cons2(Y, Z)) -> FST2(X, Z)
fst2(0, Z) -> nil
fst2(s1(X), cons2(Y, Z)) -> cons2(Y, fst2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
len1(nil) -> 0
len1(cons2(X, Z)) -> s1(len1(Z))
fst2(0, x0)
fst2(s1(x0), cons2(x1, x2))
from1(x0)
add2(0, x0)
add2(s1(x0), x1)
len1(nil)
len1(cons2(x0, x1))
The following pairs can be strictly oriented and are deleted.
The remaining pairs can at least by weakly be oriented.
FST2(s1(X), cons2(Y, Z)) -> FST2(X, Z)
trivial
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
fst2(0, Z) -> nil
fst2(s1(X), cons2(Y, Z)) -> cons2(Y, fst2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
len1(nil) -> 0
len1(cons2(X, Z)) -> s1(len1(Z))
fst2(0, x0)
fst2(s1(x0), cons2(x1, x2))
from1(x0)
add2(0, x0)
add2(s1(x0), x1)
len1(nil)
len1(cons2(x0, x1))